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(57) A multiprocessor computer system is config- 
ured to selectively transmit address transactions using 
either a broadcast mode or a point-to-point mode. De- 
pending on the mode of transmission selected, either a 
directory-based coherency protocol or a broadcast 
snooping coherency protocol is implemented to main- 
tain coherency within the system. A computing node is 
formed by a group of clients which share a common ad- 
dress and data network. The address network is config- 
ured to determine whether a particular transaction is to 
be conveyed in broadcast mode or point-to-point mode. 
In one embodiment, the address network includes a 
mode table with entries which are configurable to indi- 



cate transmission modes corresponding to different re- 
gions of the address space within the node. Upon re- 
ceiving a coherence request transaction, the address 
network may then access the table in order to determine 
the transmission mode, broadcast or point-to-point, 
which corresponds to the received transaction. In a fur- 
ther embodiment, network congestion may be moni- 
tored and transmission modes adjusted accordingly. For 
example, when network utilization is high, the number 
of transactions which are broadcast may be reduced. 
Alternatively, when network utilization is low, the number 
of broadcasts may be increased to take advantage of 
available bandwidth. 
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Description 

1. Field of the Invention 

[0001] This invention relates to the field of multiproc- s 
essor computer systems and, more particularly, to co- 
herency protocols employed within multiprocessor com- 
puter systems having shared memory architectures. 

2. Description of the Related Art 

[0002] Multiprocessing computer systems include 
two or more processors which may be employed to per- 
form computing tasks. A particular computing task may 
be performed upon one processor while other proces- 
sors perform unrelated computing tasks. Alternatively, 
components of a particular computing task may be dis- 
tributed among multiple processors to decrease the time 
required to perform the computing task as a whole. 
[0003] A popular architecture in commercial multi- 
processing computer systems is a shared memory ar- 
chitecture in which multiple processors share a common 
memory. In shared memory multiprocessing systems, a 
cache hierarchy is typically implemented between the 
processors and the shared memory. In order to maintain 
the shared memory model, in which a particular address 
stores exactly one data value at any given time, shared 
memory multiprocessing systems employ cache coher- 
ency. Generally speaking, an operation is coherent if the 
effects of the operation upon data stored at a particular 
memory address are reflected in each copy of the data 
within the cache hierarchy. For example, when data 
stored at a particular memory address Is updated, the 
update may be supplied to the caches which are storing 
copies of the previous data. Alternatively, the copies of 
the previous data may be invalidated in the caches such 
that a subsequent access to the particular memory ad- 
dress causes the updated copy to be transferred from 
main memory. 

[0004] Shared memory multiprocessing systems gen- 
erally employ either a broadcast snooping cache coher- 
ency protocol or a directory based cache coherency pro- 
tocol. In a system employing a snooping broadcast pro- 
tocol (referred to herein as a "broadcast" protocol), co- 
herence requests are broadcast to all processors (or 
cache subsystems) and memory through a totally or- 
dered network. By delivering coherence requests in a 
total order, correct coherence protocol behavior is main- 
tained since all processors and memories observe re- 
quests in the same order. When a subsystem having a 
shared copy of data observes a coherence request for 
exclusive access to the block, Its copy is typically inval- 
idated. Likewise, when a subsystem that currently owns 
a block of data observes a coherence request to that 
block, the owning subsystem typically responds by pro- 
viding the data to the requestor and invalidating its copy, 
if necessary. 

[0005] In contrast, systems employing directory 



based protocols maintain a directory containing infor- 
mation indicating the existence of cached copies of da- 
ta. Rather than unconditionally broadcasting coherence 
requests, a coherence request is typically conveyed 
through a point-to-point networkto the directory and, de- 
pending upon the information contained in the directory, 
subsequent transactions are sent to those subsystems 
that may contain cached copies of the data in order to 
cause specific coherency actions. For example, the di- 
rectory may contain information indicating that various 
subsystems contain shared copies of the data. In re- 
sponse to a coherency request for exclusive access to 
a block, invalidation transactions may be conveyed to 
the sharing subsystems. The directory may also contain 
information indicating subsystems that currently own 
particular blocks of data. Accordingly responses to co- 
herency requests may additionally include transactions 
that cause an owning subsystem to convey data to a 
requesting subsystem. In some directory based coher- 
ency protocols, specifically sequenced invalidation and/ 
or acknowledgment messages are required. Numerous 
variations of directory based cache coherency protocols 
are well known. 

[0006] In certain situations or configurations, systems 
employing broadcast protocols may attain higher per- 
formance than comparable systems employing directo- 
ry based protocols since coherence requests may be 
provided directly to all processors unconditionally with- 
out the indirection associated with directory protocols 
and without the overhead of sequencing invalidation 
and/or acknowledgment messages. However, since 
each coherence request must be broadcast to all other 
processors, the bandwidth associated with the network 
that interconnects the processors in a system employing 
a broadcast snooping protocol can quickly become a 
limiting factor in performance, particularly for systems 
that employ large numbers of processors or when a 
large number of coherence requests are transmitted 
during a short period. In such environments, systems 
employing directory protocols may attain overall higher 
performance due to lessened network traffic and the 
avoidance of network bandwidth bottlenecks. 
[0007] Thus, while the choice of whether to implement 
a shared memory multiprocessing system using a 
broadcast snooping protocol or a directory based pro- 
tocol may be clear based upon certain assumptions re- 
garding network traffic and bandwidth, these assump- 
tions can often change based upon the utilization of the 
machine. This is particularly true in scalable systems in 
which the overall numbers of processors connected to 
the network can vary significantly depending upon the 
configuration. 

SUMMARY OF THE INVENTION 

[0008] Particular and preferred aspects of the inven- 
tion are set out in the accompanying independent and 
dependent claims. Features of the dependent claims 
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may be combined with those of the independent claims 
as appropriate and in combinations other than those ex- 
plicitly set out in the claims. 

[0009] The problems outlined above may in large part 
be solved by a method and mechanism as described 
herein. Broadly speaking, a multiprocessor computer 
system configured to selectively transmit address trans- 
actions using either a broadcast mode or a point-to-point 
mode is contemplated. Depending on the mode of trans- 
mission selected, either a directory-based coherency 
protocol or a broadcast snooping coherency protocol is 
implemented to maintain coherency within the system. 
[0010] In one embodiment, a computing node is 
formed by a group of clients which share a common ad- 
dress and data network. Clients may include processing 
subsystems, memory subsystems, I/O bridges, or other 
devices. Generally speaking, memory subsystems cou- 
pled to the common address and data networks may be 
shared by other clients within the node. Further, 
processing subsystems may include caches for storing 
copies of the shared memory data. Clients initiating a 
coherence request transaction transmitted via the 
shared address network are unaware of whether the 
transaction will be conveyed within the node via a broad- 
cast or a point-to-point mode transmission. Rather, the 
address network is configured to determine whether a 
particular transaction is to be conveyed in broadcast 
mode or point-to-point mode. In one embodiment, the 
address network includes a mode table with entries 
which are configurable to indicate transmission modes 
corresponding to different regions of the address space 
within the node. Upon receiving a coherence request 
transaction, the address network may then access the 
table in order to determine the transmission mode, 
broadcast or point-to-point, which corresponds to the re- 
ceived transaction. 

[0011] In addition, it is contemplated that the above 
address network may adapt to conditions within the 
node by changing the transmission modes correspond- 
ing to received transactions. In one embodiment, net- 
work congestion may be monitored and transmission 
modes adjusted accordingly. For example, when net- 
work utilization is high, the number of transactions which 
are broadcast may be reduced. Alternatively, when net- 
work utilization is low, the number of broadcasts may be 
increased to take advantage of available bandwidth. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[001 2] Other objects and advantages of the invention 
will become apparent upon reading the following de- 
tailed description and upon reference to the accompa- 
nying drawings in which: 

Fig. 1 is a block diagram of a multiprocessing node. 

Fig. 2 is a diagram illustrating an address switch and 
memory devices. 
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Fig. 3 is a diagram of a portion of a mode table in 
an address switch. 

Fig. 4 is a diagram of a directory in a memory de- 
s vice. 

Fig. 5 is a flowchart illustrating a method of deter- 
mining a mode of conveyance for a request. 

10 Fig. 6 is a flowchart illustrating a method for adapt- 
ing a mode of conveyance. 

Fig. 7 is a block diagram of an active device in the 
system of Fig. 1. 

15 

Figs. 8A-8D are diagrams illustrating directory 
based coherence scenarios. 

Fig. 9 is a block diagram of a multi-node computer 
20 system including the node of Fig. 1 . 

[0013] While the invention is susceptible to various 
modifications and alternative forms, specific embodi- 
ments thereof are shown by way of example in the draw- 

25 jngs and will herein be described in detail. It should be 
understood, however, that the drawings and detailed de- 
scription thereto are not intended to limit the invention 
to the particular form disclosed, but on the contrary, the 
intention is to cover all modifications, equivalents and 

30 alternatives falling within the spirit and scope of the 
present invention as defined by the appended claims. 

DETAILED DESCRIPTION OF THE INVENTION 

35 Node Overview 

[0014] Fig. 1 is a block diagram of one embodiment 
of a computer system 140 which is configured to main- 
tain coherency by utilizing both broadcast and directory- 

40 based protocols. Computer system 140 includes 
processing subsystems 142A and 142B, memory sub- 
systems 144A and 144B, and an I/O subsystem 146 in- 
terconnected through an address network 1 50 and a da- 
ta network 152. Computer system 140 may be referred 

45 to as a "node". As used herein, the term "node" refers 
to a group of clients which share common address and 
data networks. In the embodiment of Fig. 1, each of 
processing subsystems 142, memory subsystems 144, 
and I/O subsystem 1 46 may be considered a client. It is 

so noted that, although five clients are shown in Fig. 1 , em- 
bodiments of computer system 140 employing any 
number of clients are contemplated. Elements referred 
to herein with a particular reference number followed by 
a letter will be collectively referred to by the reference 

55 number alone. For example, processing subsystems 
142A-142B will be collectively referred to as processing 
subsystems 142. 

[0015] Generally speaking, each of processing sub- 
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systems 142 and I/O subsystem 146 may access mem- 
ory subsystems 144. Each client in Fig. 1 may be con- 
figured to convey address transactions on address net- 
work 150 and data on data network 152 using split- 
transaction packets. Typically, processing subsystems 
142 include one or more instruction and data caches 
which may be configured in any of a variety of specific 
cache arrangements. For example, set-associative or 
direct-mapped configurations may be employed by the 
caches within processing subsystems 142. Because 
each of processing subsystems 142 within node 140 
may access data in memory subsystems 1 44, potential- 
ly caching the data, coherency must be maintained be- 
tween processing subsystems 142 and memory sub- 
systems 144, as will be discussed further below. 
[0016] Memory subsystems 144 are configured to 
store data and instruction code for use by processing 
subsystems 142 and I/O subsystem 146. Memory sub- 
systems 1 44 preferably comprise dynamic random ac- 
cess memory (DRAM), although other types of memory 
may be used. Each address in the address space of 
node 1 40 may be assigned to a particular memory sub- 
system 144, referred to as the home subsystem of the 
address. Further, each memory subsystem 144 may in- 
clude a directory suitable for implementing a directory- 
based coherency protocol. In one embodiment, each di- 
rectory may be configured to track the states of memory 
locations assigned to that memory subsystem within 
node 140. For example, the directory of each memory 
subsystem 144 may include information indicating 
which client in node 1 40 currently owns a particular por- 
tion, or block, of memory and/or which clients may cur- 
rently share a particular memory block. Additional de- 
tails regarding suitable directory implementations will be 
discussed further below. 

[0017] In the embodiment shown, data network 152 
is a point-to-point network. However, it is noted that in 
alternative embodiments other networks may be used. 
In a point-to-point network, individual connections exist 
between each client within the node 140. A particular 
client communicates directly with a second client via a 
dedicated link. To communicate with a third client, the 
particular client utilizes a different link than the one used 
to communicate with the second client. 
[0018] Address network 1 50 accommodates commu- 
nication between processing subsystems 142 , memory 
subsystems 144, and I/O subsystem 146. Operations 
upon address network 150 may generally be referred to 
as address transactions. When a source or destination 
of an address transaction is a storage location within a 
memory subsystem 144, the source or destination is 
specified via an address conveyed with the transaction 
upon address network 150. Subsequently, data corre- 
sponding to the transaction on the address network 1 50 
may be conveyed upon data network 152. Typical ad- 
dress transactions correspond to read or write opera- 
tions. A read operation causes transfer of data from a 
source outside of the initiator to a destination within the 
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initiator. Conversely, a write operation causes transfer 
of data from a source within the initiator to a destination 
outside of the initiator. In the computer system shown in 
Fig. 1 , a read or write operation may include one or more 
5 transactions upon address network 150 and data net- 
work 152. 

[001 9] As will be described in further detail below, ad- 
dress network 150 is configured to selectively transmit 
coherence requests corresponding to read or write 

10 memory operations using either a broadcast mode 
transmission or a point-to-point mode transmission 
mode. For coherence requests which are conveyed 
point-to-point by address network 150, a directory- 
based coherency protocol is implemented. Conversely, 

15 when coherence requests are conveyed using a broad- 
cast mode transmission, a snooping broadcast coher- 
ency protocol is implemented. Advantageously, node 
1 40 may realize some of the benefits pertaining to both 
protocols. 

20 [0020] In one embodiment, clients initiating a coher- 
ence request transmitted to address network 150 are 
unaware of whether the transaction will be conveyed 
within node 1 40 via a broadcast or a point-to-point mode 
transmission. In such an embodiment, address network 

25 150 is configured to determine whether a particular 
transaction is to be conveyed in broadcast (BC) mode 
or point-to-point (PTP) mode. In the following discus- 
sion, an embodiment of address network 150 which in- 
cludes a table for classifying transactions as either BC 

30 mode or PTP mode is described. 

Hybrid Network Switch 

[0021] Fig. 2 is a diagram illustrating a portion of one 

35 embodiment of node 1 40. Depicted in Fig. 2 are address 
network 1 50, memory subsystems 1 44, processing sub- 
systems 142, and I/O subsystem 146. In the embodi- 
ment shown, address network 1 50 includes a switch 200 
including a mode control unit 250 and ports 230A-230E. 

40 Mode unit 250 illustratively includes a mode table 260 
configured to store an indication of a mode of convey- 
ance, BC or PTP, for received coherency requests. 
Mode unit may comprise special task oriented circuitry 
(e.g., ASIC) or more general purpose processing circuit- 

45 ry executing software instructions. Processing units 
142A-142B each include a cache 280 configured to 
store memory data. Memory subsystems 144A and 
144B are coupled to switch 200 via ports 230B and 
230D, respectively, and include controller circuitry 210, 

50 a directory 220, and storage 225. In the embodiment 
shown, ports 230 may comprise bi-directional links or 
multiple unidirectional links. Storage 225 may comprise 
RAM, or any other suitable storage device. 
[0022] Also illustrated in Fig. 2 is a bus 270 coupled 

55 between a service processor (not shown), switch 200 
and memory subsystems 144. The service processor 
may utilize bus 270 to configure and/or initialize switch 
200 and memory subsystems 144, as will be described 
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below. The service processor may be external to node 
1 40 or may be a client included within node 1 40. 
[0023] As previously described, address network 1 50 
is configured to facilitate communication between cli- 
ents within node 140. In the embodiment of Fig. 2, 
processing subsystems 142 may perform reads or 
writes which cause transactions to occur on address 
network 150. For example, a processing unit within 
processing subsystem 142A may perform a read to a 
memory location A which misses in cache 280A. In re- 
sponse to detecting the cache miss; processing subsys- 
tem 142A may convey a read request for location A to 
switch 200 via port 230 A. Mode unit 250 detects the read 
request for location A and determines the transmission 
mode corresponding to the read request. In embodi- 
ments utilizing a mode table, the mode unit determines 
the transmission mode by consulting mode table 260. 
In one embodiment, the read request includes an ad- 
dress corresponding to location A which is used to index 
into an entry in mode table 260. The corresponding entry 
may include an indication of the home memory subsys- 
tem corresponding to location A and a mode of trans- 
mission corresponding to location A. 
[0024] In the above example, location A may corre- 
spond to a memory location within storage 225A of 
memory subsystem 144A. Consequently, the entry in 
mode table 260 corresponding to the read request may 
indicate memory subsystem 1 44A is a home subsystem 
of location A. If the entry in mode table 260 further indi- 
cates that the address of the read request is designated 
for PTP mode transmissions, switch 200 is configured 
to convey a corresponding request only to memory sub- 
system 144A via port 230B (i.e., to the home subsys- 
tem). On the other hand, if the entry in mode table 260 
indicates a BC transmission mode, switch 200 may be 
configured to broadcast a corresponding request to 
each client within node 140. Advantageously, switch 
200 may be configured to utilize either PTP or BC modes 
as desired. Consequently, in this particular embodiment 
a single encoding for a transaction conveyed by an ini- 
tiating device may correspond to either a BC mode or 
PTP mode transaction. The mode is determined not by 
the client initiating a transaction, but by the address net- 
work. The transmission mode associated with switch 
200 may be set according to a variety of different criteria. 
For example, where it is known that a particular address 
space includes widely shared data, mode unit 250 may 
be configured to utilize BC mode transactions. Con- 
versely, for data which is not widely shared, or data such 
as program code which is read only, mode unit 250 may 
be configured to utilize PTP mode. Further details re- 
garding various other criteria for setting the mode of 
switch 200 will be described further below. 

Transmission Mode Table 

[0025] Turning to Fig. 3, one embodiment of a mode 
table 260 is shown. While the embodiment of Fig. 3 
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shows mode table 260 as being included within mode 
unit 250, mode table 260 may be external to mode unit 
250. Mode table 260 may comprise a dynamic data 
structure maintained within a storage device, such as 

5 RAM or EEPROM. In the embodiment of Fig. 3, table 
260 is depicted as including columns 502, 504 and 506, 
and rows 51 0. Each row 51 0 corresponds to a particular 
address space. For example, each row 510 may corre- 
spond to a particular page of memory, or any other por- 

10 tion of address space. In one embodiment, the address 
space corresponding to a node 140 is partitioned into 
regions called "frames". These frames may be equal or 
unequal in size. Address column 502 includes an indi- 
cation of the frame corresponding to each row 510. 

15 Home column 504 includes an indication of a home sub- 
system corresponding to each row 510. Mode column 
506 includes an indication of a transmission mode, BC 
or PTP, corresponding to each row 51 0 (and thus mem- 
ory frame). 

20 [0026] In the embodiment shown in Fig. 3, table 260 
entries are directly mapped to a specific location. How- 
ever, table 260 may be organized in an associative or 
other manner. Therefore, row 51 OA corresponds to en- 
try A, row 51 0B corresponds to entry B, and so on. In a 
25 direct mapped implementation, table 260 need not ac- 
tually include address column 502; however, it is illus- 
trated for purposes of discussion. Each row 510 in the 
embodiment shown corresponds to an address space 
of equal size. As stated previously, table 260 may be 
30 initialized by a service processor coupled to switch 200. 
[0027] As illustrated in Fig. 3, row 51 OA contains an 
entry corresponding to address region A 502. In one em- 
bodiment, mode unit 250 may utilize a certain number 
of bits of an address to index into table 260. For exam- 
35 pie, address "A" in row 51 OA may correspond to a cer- 
tain number of most significant bits of an address space 
identifying a particular region. Row 51 OA indicates a 
home 504 subsystem corresponding to "A" is CLIENT 
3. Further, row 51 OA indicates the mode 506 of trans- 
40 mission for transactions within the address space cor- 
responding to region "A" is PTP. Row 51 0B corresponds 
to a region of address 502 space "B", has a home 504 
subsystem of CLIENT 3, and a transmission mode 506 
of BC. Each of the other rows 51 0 in table 260 includes 
45 similar information. 

[0028] While the above description contemplates a 
mode unit 250 which includes a mode table 260 for de- 
termining a transmission mode corresponding to re- 
ceived transactions, other embodiments are possible as 
so well. For example, mode unit 250 may be configured to 
select a transmission mode based on network traffic. In 
such an implementation, mode unit 250 may be config- 
ured to monitor link utilization and/or the state of input/ 
output queues within switch 200. If mode unit 250 de- 
55 tects that network congestion is low, a transaction may 
be broadcast to take advantage of available bandwidth. 
On the other hand, if the mode unit 250 detects that net- 
work congestion is high, a transaction may be conveyed 
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point-to-point in order to reduce congestion. Other em- 
bodiments may include tracking which address regions 
are widely shared and using broadcast transactions for 
those regions. If it is determined a particular address 
region is not widely shared or is read-only code, a point- 
to-point mode may be selected for conveying transac- 
tions for those regions. Alternatively, a service proces- 
sor coupled to switch 250 may be utilized to monitor net- 
work conditions. In yet a further embodiment, the mode 
unit 250 may be configured such that all requests are 
serviced according to PTP mode transmissions or, al- 
ternatively, according to BC mode transmissions. For 
example, in scalable systems, implementations includ- 
ing large numbers of processors may be configured 
such that mode unit 250 causes all transactions to be 
serviced according to PTP mode transmissions, while 
implementations including relatively small numbers of 
processors may be set according to BC mode transmis- 
sions. These and other embodiments are contemplated. 
[0029] As mentioned above, when switch 200 re- 
ceives a coherence request, mode unit 250 utilizes the 
address corresponding to the received transaction as 
an index into table 260. In the embodiment shown , mode 
unit 250 may utilize a certain number of most significant 
bits to form the index which is used. The index is then 
used to select a particular row 510 of table 260. If the 
mode 506 indication within the selected row indicates 
PTP mode, a corresponding transaction is conveyed on- 
ly to the home subsystem indicated by the home 504 
entry within the row. Otherwise, if the mode 506 entry 
indicates BC mode, a corresponding transaction is 
broadcast to clients within the node. In alternative em- 
bodiments, different "domains" may be specified within 
a single node. As used herein, a domain is a group of 
clients that share a common physical address space. In 
a system where different domains exist, a transaction 
which is broadcast by switch 200 may be only broadcast 
to clients in the domain which corresponds to the re- 
ceived transaction. Still further, in an alternative embod- 
iment, BC mode transactions may be broadcast only to 
clients capable of caching data and to the home memory 
subsystem. In this manner, certain transactions which 
may be unnecessary may be avoided while still imple- 
menting a broadcast snooping style coherence protocol. 

Directories 

[0030] As stated previously, for transactions which 
are conveyed in point-to-point mode by switch 200, a 
directory based coherence protocol is implemented. As 
shown in Fig. 2, each memory subsystem 144 includes 
a directory 220A which is used to implement a directory 
protocol. Fig. 4 illustrates one example of a directory 
220A which may be maintained by a controller 21 OA 
within a memory subsystem 144A. Directory 220A in- 
cludes an entry 620 for each memory block within stor- 
age 225A for which memory subsystem 144A is the 
home subsystem. In one embodiment, directory 220A 



maintains an entry 620 for each cache line whose home 
is memory subsystem 1 44A. In addition, directory 220A 
includes an entry for each client, 604-612, within node 
1 40 which may have a copy of the corresponding cache 
5 line. Directory 220A also includes an entry 614 indicat- 
ing the current owner of the corresponding cache line. 
Each entry in table 220A indicates the coherency state 
of the corresponding cache line in each client in the 
node. I n the example of Fig. 4, a region of address space 
10 corresponding to a frame "A" may be allocated to mem- 
ory subsystem 144A. Typically, the size of frame A may 
be significantly larger than a cache line. Consequently, 
table 220A may include several entries (I.e., Aa, Ab, Ac, 
etc.) which correspond to frame A. 
'5 [0031] It is noted that numerous alternative directory 
formats to support directory based coherency protocols 
are possible. For example, while the above description 
includes an entry 604-612 for each client within a node, 
an alternative embodiment may only include entries for 
groups of clients. For example, clients within a node may 
be grouped together or categorized according to a par- 
ticular criteria. For example, certain clients may be 
grouped into one category for a particular purpose while 
others are grouped into another category. In such an 
embodiment, rather than including an indication for eve- 
ry client in a group, a directory within a memory subsys- 
tem 1 44 may only include an indication as to whether a 
group may have a copy of a particular memory block. If 
a request is received for a memory block at a memory 
subsystem 144 and the directory indicates a group "B M 
may have a copy of the memory block, a corresponding 
coherency transaction may be conveyed to all clients 
within group " B" . Advantageously, by maintaining en- 
tries corresponding to groups of clients, directories 220 
may be made smaller than if an entry were maintained 
for every client in a node. 

[0032] Alternative embodiments of directories 220 are 
possible as well. In one embodiment, each directory 220 
may be simplified to only include an indication that any 
one or more clients in a node may have a copy of a par- 
ticular memory block. 

[0033] By maintaining a directory as described above, 
appropriate coherency actions may be performed by a 
particular memory subsystem (e.g., invalidating shared 
copies, requesting transfer of modified copies, etc.) ac- 
cording to the information maintained by the directory. 
A controller 210 within a subsystem 144 is generally 
configured to perform actions necessary for maintaining 
coherency within a node according to a specific direc- 
tory based coherence protocol. For example, upon re- 
ceiving a request for a particular memory block at a 
memory subsystem 144, a controller 210 may deter- 
mine from directory 220 that a particular client may have 
a copy of the requested data. The controller 210 may 
then convey a message to that particular client which 
indicates the memory block has been requested. The 
client may then respond with data if the memory block 
is modified, with an acknowledgement, or any other 
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message that is appropriate to the implemented specific 
coherency protocol. In general, memory subsystems 
144 need only maintain a directory and controller suita- 
ble for implementing a directory-based coherency pro- 
tocol. As used herein, a directory based cache coher- s 
ence protocol is any coherence protocol that maintains 
a directory containing information regarding cached 
copies of data, and in which coherence commands for 
servicing a particular coherence request are dependent 
upon the information contained in the directory. 
[0034] In one embodiment, the well known MOSI 
cache coherency protocol may be utilized by memory 
subsystems 144. In such a protocol, a memory block 
may be in one of four states: Modified (M), Owned (O), 
Shared (S), and Invalid (I). The M state includes owner- 
ship and read/write access. The O state indicates own- 
ership and read access. The shared state indicates no 
ownership and read access. Finally, the I state indicates 
no ownership and no access. However, many other well 
known coherency protocols are possible and are con- 
templated. 

General Operations 

[0035] Turning next to Fig. 5, one embodiment of a 
method for mixed mode determination and transmission 
is illustrated. An address network within a node is initially 
configured (block 300). Such configuration may include 
initializing a mode control unit and/or a mode table via 
a service processor. During system operation, if the ad- 
dress network receives a transaction request from a cli- 
ent (decision block 302), the address network deter- 
mines the transmission mode (block 304) correspond- 
ing to the received request. In the above described em- 
bodiment, the mode control unit 250 makes this deter- 
mination by accessing a mode table 260. If the mode 
corresponding to the request is determined to be BC 
mode (decision block 306), a corresponding request is 
broadcast to clients in the node. In contrast, if the mode 
corresponding to the request is determined to be PTP 
mode (decision block 306), a corresponding request is 
conveyed point-to-point to the home subsystem corre- 
sponding to the request (and not unconditionally) to oth- 
er clients within the node. 

[0036] During operation, it may be desirable to 
change the configuration of switch 200 to change the 
transmission mode for certain address frames (or for the 
entire node). For example, a mode unit 250 within switch 
200 may be initially configured to classify a particular 
region of address space with a PTP mode. Subsequent- 
ly, during system operation, it may be determined that 
the particular region of address space is widely shared 
and modified by different clients within the node. Con- 
sequently, significant latencies in accessing data within 
that region may be regularly encountered by clients. 
Thus, it may be desirable to change the transmission 
mode to broadcast for that region. While transmission 
mode configuration may be accomplished by user con- 



trol via a service processor, a mechanism for changing 
modes dynamically may alternatively be employed. 
[0037] As stated previously, numerous alternatives 
are contemplated for determining when the transmis- 
sion mode of a transaction or corresponding region of 
address space may be changed. For example, in one 
embodiment an address switch or service processor 
may be configured to monitor network congestion. 
When the switch detects congestion is high, or some 
other condition is detected, the switch or service proc- 
essor may be configured to change the modes of certain 
address regions from BC to PTP in order to reduce 
broadcasts. Similarly, if the switch or service processor 
detects network congestion is low or a particular condi- 
tion is detected, the modes may be changed from PTP 
to BC. 

[0038] Fig. 6 illustrates one embodiment of a method 
for dynamically changing transmission modes corre- 
sponding to transactions within an address network. An 
initial address network configuration (block 400) is per- 
formed which may include configuring a mode table 260 
as described above or otherwise establishing a mode of 
transmission for transactions. During system operation, 
a change in the transmission mode of switch 200 may 
be desired in response to detection of a particular con- 
dition, as discussed above (decision block 402). In the 
embodiment shown, when the condition is detected (de- 
cision block 402), new client transactions are temporar- 
ily suspended (block 404), outstanding transactions 
within the node are allowed to complete (block 408), and 
the mode is changed (block 410). In one embodiment, 
changing the mode may comprise updating the entries 
of mode table 260 as described above. It is further noted 
that to accommodate transitions from broadcast mode 
to point-to-point mode, directory information (e.g., infor- 
mation which indicates an owning subsystem) may be 
maintained even for broadcast mode transactions. 
[0039] Generally speaking, suspending clients (block 
404) and allowing outstanding transactions within the 
node to complete (block 408) may be referred to as al- 
lowing the node to reach a quiescent state. A quiescent 
state may be defined as a state when all current traffic 
has reached its destination and there is no further traffic 
entering the node. Alternative embodiments may per- 
form mode changes without requiring a node to reach a 
quiescent state. For example, rather than waiting for all 
transactions to complete, a mode change may be made 
upon completion of all pending address transactions 
(but while data transactions are still pending). Further, 
in embodiments which establish transmission modes on 
the basis of regions of memory, as in the discussion of 
frames above, a method may be such that only those 
current transactions which correspond to the frame 
whose mode is being changed need only complete. Var- 
ious alternatives are possible and are contemplated. 
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Exemplary Processing Subsystem 

[0040] Fig. 7 is a block diagram Illustrating one em- 
bodiment of a processing subsystem 1 42A within a node 
1 40. Included in the embodiment of Fig. 7 are a process- 
ing unit 702, cache 71 0, and queues 720. Queues 720A- 
720B are coupled to data network 152 via data links 730, 
and queues 720C-720D are coupled to address network 
150 via address links 740. Processing unit 702 is cou- 
pled to cache 710. 

[0041] In one embodiment, processing unit 702 is 
configured to execute instructions and perform opera- 
tions on data stored in memory subsystems 144. Cache 
710 may be configured to store copies of instructions 
and/or data retrieved from memory subsystems 144. In 
addition to storing copies of data and/or instructions, 
cache 71 0 also includes state information 71 2 indicating 
the coherency state of a particular memory block within 
cache 710. If processing unit 702 attempts to read or 
write to a particular memory block, and cache state info 
712 indicates processing unit 702 does not have ade- 
quate access rights to perform the desired operation (e. 
g., the memory block is invalid in the cache 71 0), an ad- 
dress transaction comprising a coherency request may 
be inserted in address out queue 720D for conveyance 
to a home subsystem of the memory block. These co- 
herency requests may be in the form of read-to-share 
and read-to-own requests. Subsequently, a valid copy 
of the corresponding memory block may be received via 
data in queue 720B. 

[0042] In addition, processing subsystem 142A may 
receive coherency demands via address in queue 
720C, such as a read-to-own or invalidate demand. If 
processing subsystem 1 42A receives a transaction cor- 
responding to a read-to-own request for a memory block 
which is modified in cache 71 0, the corresponding mem- 
ory block may be returned via data out queue 720A, and 
its state information 712 for that block may be changed 
to invalid. Alternatively, if processing subsystem 142A 
receives an invalidate demand for a memory block 
whose state is shared within cache 710, state informa- 
tion 712 may be changed to indicate the memory block 
is no longer valid within cache 71 0. Those skilled in the 
art will recognize there are numerous possible arrange- 
ments for caches 71 0, processing units 702, and inter- 
faces 720. 

Directory-Based Protocols 

[0043] As stated previously, any of a variety of specific 
directory-based coherence protocols may be employed 
in the system generally discussed above to service PTP 
mode coherence requests. In the following discussion, 
a variety of scenarios are depicted illustrating coherency 
activity in a node utilizing one exemplary directory- 
based coherency protocol, although it is understood that 
other specific protocols may alternatively be employed. 
[0044] Fig. 8A is a diagram depicting coherency ac- 



tivity for an exemplary embodiment of node 140 in re- 
sponse to a read-to-own (RTO) transaction upon ad- 
dress network 140. A read to own transaction may be 
performed when a cache miss is detected for a particular 

s datum requested by a processing subsystem 142 and 
the processing subsystem 142 requests write permis- 
sion to the coherency unit. A store cache miss may gen- 
erate a read to own transaction, for example. 
[0045] A request agent 100, home agent 102, and 

10 several slave agents 104 are shown in Fig. 8A. In this 
context, an "agent" refers to a mechanism in a client 
configured to initiate and respond to coherency opera- 
tions. Request agents and slave agents generally cor- 
respond to functionality within processing subsystems 

15 1 42, while a home agent generally corresponds to func- 
tionality within a home memory subsystem. 
[0046] In Fig. 8A, the requesting client 1 00 initiating a 
read to own transaction and has the corresponding co- 
herency unit in an invalid state (e.g. the coherency unit 

20 is not stored in the client). The subscript Y in request 
client 100 indicates the invalid state. The home client 
102 stores the coherency unit in the shared state, and 
clients corresponding to several slave agents 1 04 store 
the coherency unit in the shared state as well. The sub- 

25 script "s" in home agent 1 02 and slave agents 1 04 is 
indicative of the shared state at those clients. The read 
to own transaction generally causes transfer of the re- 
quested coherency unit to the requesting client. As used 
herein, a "coherency unit" is a number of contiguous 

30 bytes of memory which are treated as a unit for coher- 
ency purposes. For example, if one byte within the co- 
herency unit is updated, the entire coherency unit is con- 
sidered to be updated. In one specific embodiment, the 
coherency unit is a cache line. 

35 [0047] Upon detecting a cache miss, request agent 
100 transmits a read to own coherency request to the 
home client 102 (e.g., the home memory subsystem) of 
the coherency unit (reference number 130). The home 
agent 102 in the receiving home client detects the 

40 shared state for one or more other clients. Since the 
slave agents 1 04 are each in the shared state, not the 
owned state, the home client 102 may supply the re- 
quested data directly to the requesting client 1 00. Home 
agent 102 transmits a data coherency reply to request 

45 agent 100, including the data corresponding to the re- 
quested coherency unit (reference number 1 32). Home 
agent 102 updates its directory to indicate that the re- 
questing client 100 is the owner of the coherency unit, 
and that each of the other clients is invalid. Home agent 

so 1 02 transmits invalidate coherency demands to each of 
the slave agents 1 04 which are maintaining shared cop- 
ies of the affected coherency unit (reference number 
134). The invalidate coherency demand causes the re- 
ceiving slave agent to invalidate the corresponding co- 

55 herency unit within the slave client. In the example 
shown, the invalidate coherency demands are con- 
veyed from a single point, home agent 102, to multiple 
points, slave agents 104. Consequently, the convey- 



8 



EP001 255201 fhttp://www.q etthepatent. comyLogin.doq/$pkennedy/@5681%2D951 01 /Fetch/EP001 255201. cpc?pnum=EP001255201toolpar=bottornpaPage 9 of 24 



15 



EP 1 255 201 A1 



ance of the invalidation coherency demands may be 
considered a multicast. Subsequent to receiving the da- 
ta coherency reply from home agent 1 02, request agent 
1 00 validates the coherency unit within its local memory. 
[0048] Fig. 8B is a diagram depicting coherency ac- 
tivity in response to a read-to-own request when a slave 
agent 1 03 is the current owner of the coherency unit and 
other slave agents 104 have shared copies of the co- 
herency unit. The request agent 1 00 initiates the trans- 
action by sending a read-to-own request to home agent 
102 (reference number 133A). In one embodiment, this 
causes home agent 102 to block new transactions to 
this coherency unit. Home agent 1 02 marks the reques- 
tor 1 00 as the sole owner of the line and sends an RTO 
demand to the owning slave agent 103 (reference 
number 133B). Home agent also sends invalidate co- 
herency demands to all other slave agents 104 with a 
shared copy (reference number 133C). The owning 
slave agent 1 03 replies with data to the requesting agent 
100 (reference number 133D) and invalidates its copy. 
[0049] Fig. 8C illustrates a transaction wherein re- 
quest agent 100 has a shared copy and sends a read- 
to-own request to home agent 102 (reference number 
135A). When home agent 102 receives the read-to-own 
request, home agent 1 02 may block furthertransactions 
to this line. Home agent 102 further sends invalidation 
demands (reference number 135B) to all other clients 
with a copy of the line (not to the requestor, however). 
Home agent 1 02 further marks request agent 1 00 as the 
sole owner. All slave agents (103 and 104) invalidate 
their copies. Finally, home agent 1 02 removes the block 
on transactions to that line and conveys an indication 
1 35C to the request agent 1 00 that no other valid copies 
exist in the node. 

[0050] Fig. 8D depicts coherency activity in response 
to a read-to-share (RTS) request when a slave is the 
owner of the coherency unit. Similar to the above de- 
scription, the coherency activity initiates when the re- 
quest agent 100 sends a read-to-share request to the 
home agent 102 (reference number 137A). This causes 
home agent 102 to block new transactions to this line. 
Home agent 102 marks the requestor 100 as a sharer 
and sends a read-to-share demand to the owner slave 
agent 103 (reference number 137B). The owning slave 
agent 103 replies with data to the request agent 100 (ref- 
erence number 137C) and remains in the owned state. 
[0051 ] The above scenarios are intended to be exem- 
plary only. Numerous alternatives for implementing a di- 
rectory-based coherency protocol are possible and are 
contemplated. For example, in the scenario of Fig. 8A, 
the data coherency reply 1 32 from home agent 1 02 may 
serve to indicate no other valid copies remain within the 
client. In alternative embodiments, where ordering with- 
in the network is not sufficiently strong, various forms of 
acknowledgements (ACK) and other replies may be uti- 
lized to provide confirmation that other copies have 
been invalidated. For example, each slave agent 104 
receiving an invalidate coherency demand may respond 



16 

to the home agent 102 with an ACK. Upon receiving all 
expected ACKs, the home agent may then convey an 
indication to the request agent 1 00 that no other valid 
copies remain within the client. Alternatively, request 

5 agent may receive a reply count from home agent 102 
or a slave agent 104 indicating a number of replies to 
expect. Slave agents 1 04 may then convey ACKs direct- 
ly to the requesting client 100. Upon receiving the ex- 
pected number or replies, the request agent 100 may 

10 then determine all other copies have been invalidated. 

Virtual Networks and Ordering Points 

[0052] In one embodiment, address network 150 
'5 comprises four virtual networks: a Broadcast Network, 
a Request Network, a Response Network, and a Multi- 
cast Network. Each virtual network may be configured 
to operate in logically different ways. For example, the 
Broadcast Network may implement a logical broadcast 
20 medium between client devices within a node and is only 
used for BC mode transactions. The Request Network 
may implement a logical point-to-point medium between 
client devices in a node and may only be used for PTP 
mode transactions. In one embodiment, coherence re- 
25 quests sent on the Request Network are sent to the de- 
vice which maps the memory location corresponding to 
the transaction. The Response Network may also im- 
plement a logical point-to-point medium between client 
devices in a node and may only be used for PTP mode 
30 transactions. Packets sent on the Response Network 
may implement requests for data transfers. In one em- 
bodiment, packets sent on the Response Network are 
only sent to requesting and/or owning clients. Finally, 
the Multicast Network may implement a logical point-to- 
35 multipoint medium between client devices in a node and 
is used only for PTP mode transactions. In one embod- 
iment, packets sent on the Multicast Network are sent 
to the requesting client and non-owning sharers. 
[0053] Thus, in the embodiment of node 140 as dis- 
40 cussed above, various ordering points are established 
within the node. These ordering points govern owner- 
ship and access right transitions. One such ordering 
point is the Broadcast Network. The Broadcast Network 
is the ordering point for cacheable BC mode transac- 
ts tions corresponding to a given memory block. All clients 
in a node or domain receive broadcast packets for a giv- 
en memory block in the same order. For example, if cli- 
ents C1 and C2 both receive broadcast packets B1 and 
B2, and C1 receives B1 before B2, then C2 also re- 
50 ceives B1 before B2. 

[0054] In other situations, a client may serve as an 
ordering point. More particularly, in the embodiment de- 
scribed above, for cacheable PTP mode address trans- 
actions, the order in which requests are serviced by the 
55 home memory subsystem directory establishes the or- 
der of the PTP mode transactions. 
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Multi-node.System 

[0055] Turning now to Fig. 9, one embodiment of a 
multi-node computer system 900. Computer system 
900 includes nodes 920A and 920B. Each of nodes 920 
are similar to the node of Fig. 1 . In addition to processing 
subsystems 142, memory subsystems 144, and I/O 
subsystem 146, each node 920 includes an scalable 
shared memory (SSM) subsystem 902. SSM subsystem 
902 is coupled to address network 1 50 and data network 
152. Further, SSM subsystems 902 are coupled to a glo- 
bal interconnect 950. In a multi-node computer system 
900 as shown in Fig. 9, global interconnect serves as a 
communication medium between nodes 902. Conse- 
quently, data may not only be shared within a particular 
node 902A, but may also be shared between nodes 902 
within a system 900. Generally, SSM subsystem 902 is 
configured to provide a communication interface be- 
tween a node 902 and global interconnect 950. 
[0056] Numerous variations and modifications will be- 
come apparent to those skilled in the art once the above 
disclosure is fully appreciated. It is intended that the fol- 
lowing claims be interpreted to embrace all such varia- 
tions and modifications. 



Claims 

1 . A multiprocessing system comprising: 

a plurality of processing subsystems, each in- 
cluding a cache memory; 
a memory subsystem including a directory; 
a network interconnecting said plurality of 
processing subsystems and said memory sub- 
system; 

a coherency mode storage unit configured to 
store an indication to control whether a given 
coherency request is transmitted through said 
network according to a directory protocol or a 
broadcast protocol. 

2. The multiprocessing system as recited in Claim 1 
wherein said directory includes a plurality of entries 
corresponding to different memory locations 
mapped to said memory subsystem, wherein each 
entry contains information indicative of whether a 
cached copy of a corresponding block has been 
created in one or more of said plurality of processing 
subsystems. 

3. The multiprocessing system as recited in Claim 2 
wherein when said given coherency request is 
transmitted through said network according to said 
broadcast protocol, said coherency request is 
broadcasted to said memory subsystem and to 
each of said plurality of processing subsystems re- 
gardless of information contained within said direc- 



tory. 

4. The multiprocessing system as recited in Claim 3 
wherein said given coherency request is initiated by 

5 a requesting processing subsystem, and wherein 
said given coherency request is transmitted to said 
network through a point-to-point link. 

5. The multiprocessing system as recited in Claim 4 
10 wherein said given coherency request transmitted 

from said requesting processing subsystem 
through said point-to-point link does not specify 
whether said given coherency request is transmit- 
ted through said network according to said directory 
'5 protocol or said broadcast protocol. 

6. The. multiprocessing system as recited in Claim 3 
wherein when said coherency request is transmit- 
ted through said network according to said directory 

20 protocol, said given coherency request is transmit- 
ted through said network to said memory subsys- 
tem. 

7. The multiprocessing system as recited in Claim 6 
25 wherein when said given coherency request is 

transmitted through said network according to said 
directory protocol, said directory is accessed by 
said memory subsystem and responsive coherency 
commands are provided to one or more of said plu- 
30 rality of processing subsystems dependent upon in- 
formation contained within said directory. 

8. The multiprocessing system as recited in any pre- 
ceding claim wherein said coherency mode storage 

35 unit is configured to store a plurality of additional 
indications to control whether other coherency re- 
quests are transmitted through said network ac- 
cording to said directory protocol or said broadcast 
protocol. 

40 

9. The multiprocessing system as recited in Claim 8 
wherein selected coherency requests are transmit- 
ted through said network according to said directory 
protocol while other coherency requests are trans- 

45 mitted through said network according to said 
broadcast protocol. 

10. The multiprocessing system as recited in Claim 9 
wherein an address of each coherency request is 

50 used to dictate whether said each request is trans- 
mitted through said network according to said direc- 
tory protocol or said broadcast protocol. 

1 1 . A multiprocessing system comprising: 

55 

a plurality of processing subsystems, each in- 
cluding a cache memory; 
a memory subsystem including a directory; 



EP 1 255 201 A1 18 



5 



10 



15 



20 



25 



10 



EP001 255201 f http://www,qetth epatent^^ 11 of 24 



EP 1 255 201 A1 



20 



19 

a network Interconnecting said plurality of 
processing subsystems and said memory sub- 
system; 

wherein ownership transitions for a first set of cache 
lines are governed according to a sequence of ac- 
tions within said network; 

and wherein ownership transitions for a second set 
of cache lines are governed according to a se- 
quence of actions within said directory. 

12. The multiprocessing system as recited in Claim 11 
wherein said directory includes a plurality of entries 
corresponding to different memory locations 
mapped to said memory subsystem, wherein each 
entry contains information indicative of whether a 
cached copy of a corresponding block has been 
created in one or more of said plurality of processing 
subsystems. 

13. The multiprocessing system as recited in Claim 12 
further comprising a coherency mode storage unit 
configured to store an indication to control whether 
a given coherency request is transmitted through 
said network according to a directory protocol or a 
broadcast protocol, wherein when said given coher- 
ency request is transmitted through said network 
according to said broadcast protocol, said coheren- 
cy request is broadcasted to said memory subsys- 
tem and to each of said plurality of processing sub- 
systems regardless of information contained within 
said directory. 

14. The multiprocessing system as recited in Claim 13 
wherein said given coherency request is initiated by 
a requesting processing subsystem, and wherein 
said given coherency request is transmitted to said 
network through a point-to-point link. 

15. The multiprocessing system as recited in Claim 14 
wherein said given coherency request transmitted 
from said requesting processing subsystem 
through said point-to-point link does not specify 
whether said given coherency request is transmit- 
ted through said network according to said directory 
protocol or said broadcast protocol. 

16. The multiprocessing system as recited in Claim 13 
wherein when said coherency request is transmit- 
ted through said network according to said directory 
protocol, said given coherency request is transmit- 
ted through said network to said memory subsys- 
tem. 

17. The multiprocessing system as recited in Claim 16 
wherein when said given coherency request is 
transmitted through said network according to said 
directory protocol, said directory is accessed by 



said memory subsystem and responsive coherency 
commands are provided to one or more of said plu- 
rality of processing subsystems dependent upon in- 
formation contained within said directory. 

5 

18. The multiprocessing system as recited in any of 
Claims 1 1 to 1 7 wherein said coherency mode stor- 
age unit is configured to store a plurality of addition- 
al indications to control whether other coherency re- 

w quests are transmitted through said network ac- 
cording to said directory protocol or said broadcast 
protocol. 

19. The multiprocessing system as recited in Claim 18 
15 wherein selected coherency requests are transmit- 
ted through said network according to said directory 
protocol while other coherency requests are trans- 
mitted through said network according to said 
broadcast protocol. 

20 

20. The multiprocessing system as recited in Claim 19 
wherein an address of each coherency request is 
used to dictate whether said each request is trans- 
mitted through said network according to said direc- 
ts tory protocol or said broadcast protocol. 

21. A multiprocessing system comprising: 

a memory subsystem including a directory, the 
30 directory including a plurality of directory en- 

tries corresponding to memory locations 
mapped to said memory device; 
a plurality of processing subsystems each in- 
cluding a cache for storing blocks correspond- 
35 ing to selected ones of said memory locations; 

a network interconnecting said plurality of 
processing subsystems and said memory sub- 
system; 

a coherency mode storage unit configured to 
40 store an indication of whether a given block is 

a point-to-point mode block or a broadcast 
mode block; 

wherein the network is configured to route a coher- 
es ency request for said given block initiated by one of 
said processing subsystems to said directory in re- 
sponse to said indication indicating said given block 
is a point-to-point mode block, and wherein said 
network is configured to broadcast said coherency 
50 request to said memory subsystem and to each of 
said plurality of processing subsystems in response 
to said indication indicating said given block is a 
broadcast mode block. 

55 22. A multiprocessing system comprising: 

a plurality of processing subsystems, each in- 
cluding a cache memory; 
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a memory subsystem including a directory; 
a network interconnecting said plurality of 
processing subsystems and said memory sub- 
system; 

5 

wherein transitions of access rights for a first 
set of cache lines are governed according to a se- 
quence of actions within said network; 
and wherein transitions of access rights for a sec- 
ond set of cache lines are governed according to a io 
sequence of actions within said directory. 

23. A multiprocessing system comprising: 

a plurality of processing subsystems, each in- is 
eluding a cache memory; 
a memory subsystem; 

a network interconnecting said plurality of 
processing subsystems and said memory sub- 
system; 20 
a control unit configured to monitor bandwidth 
utilization of said network and to control wheth- 
er a given coherency request is transmitted 
through said network according to a directory 
protocol or a broadcast protocol depending up- 25 
on the bandwidth utilization. 

24. A method of operating a multiprocessing system in- 
cluding a plurality of processing subsystems and a 
memory subsystem interconnected through a net- so 
work, the method comprising: 

storing an indication to control whether a given 
coherency request is transmitted through said 
network according to a directory protocol or a 35 
broadcast protocol; 

a first processing subsystem initiating a coher- 
ency request; and 



said network conveying said coherency re- 
quest according to said indication. 
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